EP1471671 



Publication Title: 

Integrated memory controller circuit for fiber optics transceiver 



Abstract: 

A controller (110) for controlling a transceiver having a laser transmitter and a 
photodiode receiver. The controller includes memory (120, 122, 128) for storing 
information related to the transceiver, and analog to digital conversion circuitry 
(127) for receiving a plurality of analog signals from the laser transmitter and 
photodiode receiver, converting the received analog signals into digital values, 
and storing the digital values in predefined locations within the memory. 
Comparison logic (131) compares one or more of these digital values with limit 
values, generates flag values based on the comparisons, and stores the flag 
values in predefined locations within the memory. Control circuitry (123-1, 123-2) 
in the controller controls the operation of the laser transmitter in accordance with 
one or more values stored in the memory. A serial interface (121) is provided to 
enable a host device to read from and write to locations within the memory. 
Excluding a small number of binary input and output signals, all control and 
monitoring functions of the transceiver are mapped to unique memory mapped 
locations within the controller. A plurality of the control functions and a plurality of 
the monitoring functions of the controller are exercised by a host computer by 
accessing corresponding memory mapped locations within the controller. 
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(57) A controller (110) for controlling a transceiver 
having a laser transmitter and a photodiode receiver. 
The controller includes memory (1 20, 1 22, 1 28) for stor- 
ing information related to the transceiver, and analog to 
digital conversion circuitry (127) for receiving a plurality 
of analog signals from the laser transmitter and photo- 
diode receiver, converting the received analog signals 
into digital values, and storing the digital values in pre- 
defined locations within the memory. Comparison logic 
(131 ) compares one or more of these digital values with 
limit values, generates flag values based on the com- 
parisons, and stores the flag values in predefined loca- 
tions within the memory. Control circuitry (1 23-1 , 1 23-2) 
in the controller controls the operation of the laser trans- 
mitter in accordance with one or more values stored in 
the memory. A serial interface (121) is provided to ena- 
ble a host device to read from and write to locations with- 
in the memory. Excluding a small number of binary input 
and output signals, all control and monitoring functions 
of the transceiver are mapped to unique memory 
mapped locations within the controller. A plurality of the 
control functions and a plurality of the monitoring func- 
tions of the controller are exercised by a host computer 
by accessing corresponding memory mapped locations 
within the controller. 
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Description 

[0001] The present invention relates generally to the field of fiber optic transceivers and particularly to circuits used 
within the transceivers to accomplish control, setup, monitoring, and identification operations. 

5 

BACKGROUND OF INVENTION 

[0002] The two most basic electronic circuits within a fiber optic transceiver are the laser driver circuit, which accepts 
high speed digital data and electrically drives an LED or laser diode to create equivalent optical pulses, and the receiver 
10 circuit which takes relatively small signals from an optical detector and amplifies and limits them to create a uniform 
amplitude digital electronic output. In addition to, and sometimes in conjunction with these basic functions, there are 
a number of other tasks that must be handled by the transceiver circuitry as well as a number of tasks that may optionally 
be handled by the transceiver circuit to improve its functionality. These tasks include, but are not necessarily limited 
to, the following: 

15 

• Setup functions. These generally relate to the required adjustments made on a part-to-part basis in the factory to 
allow for variations in component characteristics such as laser diode threshold current. 

• Identification. This refers to general purpose memory, typically EEPROM (electrically erasable and programmable 
read only memory) or other nonvolatile memory. The memory is preferably accessible using a serial communication 

20 standard, that is used to store various information identifying the transceiver type, capability, serial number, and 

compatibility with various standards. While not standard, it would be desirable to further store in this memory 
additional information, such as sub-component revisions and factory test data. 

• Eye safety and general fault detection. These functions are used to identify abnormal and potentially unsafe op- 
erating parameters and to report these to the user and/or perform laser shutdown, as appropriate. 

25 

[0003] In addition, it would be desirable in many transceivers for the control circuitry to perform some or all of the 
following additional functions: 

• Temperature compensation functions. For example, compensating for known temperature variations in key laser 
30 characteristics such as slope efficiency. 

• Monitoring functions. Monitoring various parameters related to the transceiver operating characteristics and envi- 
ronment. Examples of parameters that it would be desirable to monitor include laser bias current, laser output 
power, received power level, supply voltage and temperature. Ideally, these parameters should be monitored and 
reported to, or made available to, a host device and thus to the user of the transceiver 

35 • Power on time. It would be desirable for the transceiver's control circuitry to keep track of the total number of hours 
the transceiver has been in the power on state, and to report or make this time value available to a host device. 

• Margining. "Margining" is a mechanism that allows the end user to test the transceiver's performance at a known 
deviation from ideal operating conditions, generally by scaling the control signals used to drive the transceiver's 
active components. 

40 • Other digital signals. It would be desirable to enable a host device to be able to configure the transceiver so as to 
make it compatible with various requirements for the polarity and output types of digital inputs and outputs. For 
instance, digital inputs are used for transmitter disable and rate selection functions while outputs are used to 
indicate transmitter fault and loss of signal conditions. The configuration values would determine the polarity of 
one or more of the binary input and output signals. In some transceivers it would be desirable to use the configu- 

45 ration values to specify the scale of one or more of the digital input or output values, for instance by specifying a 

scaling factor to be used in conjunction with the digital input or output value. 

[0004] Few if any of these additional functions are implemented in most transceivers, in part because of the cost of 
doing so. Some of these functions have been implemented using discrete circuitry, for example using a general purpose 
50 EEPROM for identification purposes, by inclusion of some functions within the laser driver or receiver circuitry (for 
example some degree of temperature compensation in a laser driver circuit) or with the use of a commercial micro- 
controller integrated circuit. However, to date there have not been any transceivers that provide a uniform device 
architecture that will support all of these functions, as well as additional functions not listed here, in a cost effective 
manner. 

55 [0005] It is the purpose of the present invention to provide a general and flexible integrated circuit that accomplishes 
all (or any subset) of the above functionality using a straightforward memory mapped architecture and a simple serial 
communication mechanism. 

[0006] Fig. 1 shows a schematic representation of the essential features of a typical prior-art fiber optic transceiver. 
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The main circuit 1 contains at a nninimunn transmit and receiver circuit paths and power 19 and ground connections 
1 8. The receiver circuit typically consists of a Receiver Optical Subassembly (ROSA) 2 which contains a mechanical 
fiber receptacle as well as a photodiode and pre-amplifier (preamp) circuit. The ROSA is in turn connected to a post- 
amplifier (postamp) integrated circuit 4, the function of which is to generate a fixed output swing digital signal which is 

5 connected to outside circuitry via the RX+ and RX- pins 17. The postamp circuit also often provides a digital output 
signal known as Signal Detect or Loss of Signal indicating the presence or absence of suitably strong optical input. 
The Signal Detect output is provided as an output on pin 1 8. The transmit circuit will typically consist of a Transmitter 
Optical Subassembly (TOSA), 3 and a laser driver integrated circuits. The TOSA contains a mechanical fiber receptacle 
as well as a laser diode or LED. The laser driver circuit will typically provide AC drive and DC bias current to the laser. 

10 The signal inputs for the AG driver are obtained from the TX+ and TX- pins 12. Typically, the laser driver circuitry will 
require individual factory setup of certain parameters such as the bias current (or output power) level and AC modulation 
drive to the laser. Typically this is accomplished by adjusting variable resistors or placing factory selected resistors?, 
9 (i.e., having factory selected resistance values). Additionally, temperature compensation of the bias current and 
modulation is often required. This function can be integrated in the laser driver integrated circuit or accomplished 

15 through the use of external temperature sensitive elements such as thermistors 6, 8. 

[0007] In addition to the most basic functions described above, some transceiver platform standards involve addi- 
tional functionality. Examples of this are the TX disable 13 and TX fault 14 pins described in the GBIC standard. In the 
GBIC standard, the TX disable pin allows the transmitter to be shut off by the host device, while the TX fault pin Is an 
indicator to the host device of some fault condition existing in the laser or associated laser driver circuit. In addition to 

20 this basic description, the GBIC standard includes a series of timing diagrams describing how these controls function 
and interact with each other to implement reset operations and other actions. Most of this functionality is aimed at 
preventing non-eyesafe emission levels when a fault conditions exists in the laser circuit. These functions may be 
integrated into the laser driver circuit itself or in an optional additional integrated circuit 1 1 . Finally, the GBIC standard 
also requires the EEPROM 10 to store standardized serial ID information that can be read out via a serial interface 

25 (defined as using the serial interface of the ATMEL AT24C01 A family of EEPROI\/l products) consisting of a clock 15 
and data 1 6 line. 

[0008] As an alternative to mechanical fiber receptacles, some prior art transceivers use fiber optic pigtails which 
are standard, male fiber optic connectors. 

[0009] Similar principles clearly apply to fiber optic transmitters or receivers that only implement half of the full trans- 
30 ceiver functions. 

SUMMARY OF THE INVENTION 

[0010] The present invention is preferably implemented as a single-chip integrated circuit, sometimes called a con- 
35 troller, for controlling a transceiver having a laser transmitter and a photodiode receiver. The controller includes memory 
for storing information related to the transceiver, and analog to digital conversion circuitry for receiving a plurality of 
analog signals from the laser transmitter and photodiode receiver, converting the received analog signals into digital 
values, and storing the digital values in predefined locations within the memory. Comparison logic compares one or 
more of these digital values with limit values, generates flag values based on the comparisons, and stores the flag 
40 values in predefined locations within the memory. Control circuitry in the controller controls the operation of the laser 
transmitter in accordance with one or more values stored in the memory. A serial interface is provided to enable a host 
device to read from and write to locations within the memory. A plurality of the control functions and a plurality of the 
monitoring functions of the controller are exercised by a host computer by accessing corresponding memory mapped 
locations within the controller. 

45 [0011] In some embodiments the controller further includes a cumulative clock for generating a time value corre- 
sponding to cumulative operation time of the transceiver, wherein the generated time value is readable via the serial 

interface. 

[0012] In some embodiments the controller further includes a power supply voltage sensor that generates a power 
level signal corresponding to a power supply voltage level of the transceiver. In these embodiments the analog to digital 

50 conversion circuitry is configured to convert the power level signal into a digital power level value and to store the digital 
power level value in a predefined power level location within the memory. Further, the comparison logic of the controller 
may optionally include logic for comparing the digital power level value with a power (i.e., voltage) level limit value, 
generating a flag value based on the comparison of the digital power level signal with the power level limit value, and 
storing a power level flag value in a predefined power level flag location within the memory. It is noted that the power 

55 supply voltage sensor measures the transceiver voltage supply level, which is distinct from the power level of the 
received optical signal. 

[0013] In some embodiments the controller further includes a temperature sensor that generates a temperature 
signal corresponding to a temperature of the transceiver. In these embodiments the analog to digital conversion circuitry 
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is configured to convert the temperature signal into a digital tennperature value and to store the digital temperature 
value in a predefined temperature location within the memory. Further, the comparison logic of the controller may 
optionally include logic for comparing the digital temperature value with a temperature limit value, generating a flag 
value based on the comparison of the digital temperature signal with the temperature limit value, and storing a tem- 

5 perature flag value in a predefined temperature flag location within the memory. 

[0014] In some embodiments the controller further includes "margining" circuitry for adjusting one or more control 
signals generated by the control circuitry in accordance with an adjustment value stored in the memory. 
[0015] According to a first aspect of the present invention, there is provided a single-chip integrated circuit for con- 
trolling an optoelectronic transceiver having a laser transmitter and a photodiode receiver, comprising memory, includ- 

10 ing one or more memory arrays for storing information related to the transceiver; analog to digital conversion circuitry 
for receiving a plurality of analog signals from the laser transmitter and photodiode receiver, converting the received 
analog signals into digital values, and storing the digital values in predefined locations within the memory; control 
circuitry configured to generate control signals to control operation of the laser transmitter in accordance with one or 
more values stored in the memory; an interface for reading from and writing to locations within the memory; and com- 

15 parison logic for comparing the digital values with limit values, generating flag based on the limit values, and storing 
the flag values in predefined locations within the memory. 

[0016] Advantageously, the single-chip integrated circuit further includes a cumulative clock for generating a time 
value corresponding to cumulative operation time of the transceiver, wherein the generated time value is readable via 
the interface. 

20 [0017] More advantageously, the single-chip integrated circuit further includes a power supply voltage sensor coupled 
to the analog to digital conversion circuitry, the power supply voltage sensor generating a power level signal corre- 
sponding to a power supply voltage level of the transceiver, wherein the analog to digital conversion circuitry is con- 
figured to convert the power level signal into a digital power level value and to store the digital power level value in a 
predefined power level location within the memory. 

25 [0018] Preferably the comparison logic of the signal-chip integrated circuit includes logic for comparing the digital 
power level value with a power level limit value, generating a power level flag value based on the comparison of the 
digital power level signal with the power level limit value, and storing the power level flag value in a predefined power 
level flag location within the memory. 

[0019] Preferably, the single-chip integrated circuit further includes a temperature sensor coupled to the analog to 
30 digital conversion circuitry, the temperature sensor generating a temperature signal corresponding to a temperature 
of the transceiver, wherein the analog to digital conversion circuitry is configured to convert the temperature signal into 
a digital temperature value and to store the digital temperature value in a predefined temperature location within the 
memory. 

[0020] More preferably, the comparison logic of the single-chip integrated circuit includes logic for comparing the 
35 digital temperature value with a temperature limit value, generating a temperature flag value based on the comparison 
of the digital temperature signal with the temperature limit value, and storing the temperature flag value in a predefined 
temperature flag location within the memory. 

[0021] Advantageously, the single-chip integrated circuit further includes fault handling logic, coupled to the trans- 
ceiver for receiving at least one fault signal from the transceiver, and coupled to the memory to receive at least one 

40 flag value stored in the memory, and coupled to a host interface to transmit a computed fault signal, the fault handling 
logic including computational logic for logically combining the at least one fault signal received from the transceiver 
and the at least one flag value received from the memory to generate the computed fault signal. 
[0022] According to a second aspect of the present invention, there is provided a single-chip integrated circuit for 
controlling an optoelectronic device comprising memory, including one or more memory arrays for storing information 

45 related to the optoelectronic device; analog to digital conversion circuitry for receiving a plurality of analog signals from 
the optoelectronic device, the analog signals corresponding to operating conditions of the optoelectronic device, con- 
verting the received analog signals into digital values, and storing the digital values in predefined locations within the 
memory; and a memory interface for reading from and writing to locations within the memory in accordance with com- 
mands received from a host device. 

50 [0023] According to a third aspect of the present invention, there is provided a single-chip integrated circuit for con- 
trolling an optoelectronic transceiver having a laser transmitter and a photodiode receiver, comprising analog to digital 
conversion circuitry for receiving a plurality of analog signals from the laser transmitter and photodiode receiver, con- 
verting the received analog signals into digital values, and storing the digital values in predefined memory mapped 
locations within the integrated circuit; comparison logic for comparing the digital values with limit values, generating 

55 flag values based on the limit values, and storing the flag values in predefined memory mapped locations within the 
integrated circuit; control circuitry configured to generate control signals to control operation of the laser transmitter in 
accordance with one or more values stored in the integrated circuit; and a memory mapped interface for reading from 
and writing to locations within the integrated circuit and for accessing memory mapped locations within the integrated 
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circuit for controlling operation of the control circuitry. 

[0024] According to a fourth aspect ofthe present invention there is provided a nnethod of controlling an optoelectronic 
transceiver having a laser transnnitter and a photodiode receiver comprising: in accordance with instructions received 
from a host device, reading from and writing to locations within a memory; and receiving a plurality of analog signals 
5 from the laser transmitter and photodiode receiver, converting the received analog signals into digital values, and 
storing the digital values in predefined locations within the memory; comparing the digital values with limit values, 
generating flag values based on the limit values, and storing the flag values in predefined locations within the memory; 
generating control signals to control operation of the laser transmitter in accordance with one or more values stored 
in the memory. 

10 [0025] Preferably the method of controlling an optoelectronic transceiver having a laser transmitter and a photodiode 
receiver further includes generating atime value corresponding to cumulative operation time of the transceiver, wherein 
the generated time value is readable by the host device via the memory interface. 

[0026] Advantageously, the method of controlling an optoelectronic transceiver having a laser transmitter and a pho- 
todiode receiver further includes converting an analog power supply voltage level signal, corresponding to a voltage 
^5 level of the transceiver, into a digital power level value and storing the digital power level value in a predefined power 
level location within the memory. 

[0027] More advantageously, the method of controlling an optoelectronic transceiver having a laser transmitter and 
a photodiode receiver includes comparing the digital power level value with a power level limit value, generating a 
power level flag value based on the comparison of the digital power level signal with the power level limit value, and 

20 storing the power level flag value in a predefined power level flat location within the memory. 

[0028] Advantageously, the method of controlling an optoelectronic transceiver having a laser transmitter and a pho- 
todiode receiver further includes generating a temperature signal corresponding to a temperature of the transceiver, 
converting the temperature signal into a digital temperature value and storing the digital temperature value in a pre- 
defined temperature location within the memory. 

25 [0029] More advantageously, the method of controlling an optoelectronic transceiver having a laser transmitter and 
a photodiode receiver includes comparing the digital temperature value with a temperature limit value, generating a 
temperature flag value based on the comparison of the digital temperature signal with the temperature limit value, and 
storing the temperature flag value in a predefined temperature flag location within the memory. 
[0030] Preferably, the method of controlling an optoelectronic transceiver having a laser transmitter and a photodiode 

30 receiver further includes receiving at least one fault signal from the transceiver, receiving at least one flag value stored 
in the memory, logically combining the at least one fault signal received from the transceiver and the at least one flag 
value received from the memory to generate a computed fault signal, and transmitting the computed fault signal to the 
host device. 

[0031 ] According to a fifth aspect of the present invention there is provided a method of controlling an optoelectronic 

35 device comprising: in accordance with instructions received from a host device, reading from and writing to locations 
within a memory; and receiving a plurality of analog signals from the optoelectronic device, the analog signals corre- 
sponding to operating conditions ofthe optoelectronic device, converting the received analog signals into digital values, 
and storing the digital values in predefined locations within the memory; wherein the method is performed by a single- 
chip controller integrated circuit. 

40 [0032] According to a sixth aspect of the present invention there is provided a method of controlling an optoelectronic 
transceiver having a laser transmitter and a photodiode receiver comprising: in accordance with instructions received 
from a host device, reading from and writing to memory mapped locations within a controller of the optoelectronic 
transceiver; receiving a plurality of analog signals from the laser transmitter and photodiode receiver, converting the 
received analog signals into digital values, and storing the digital values in predefined memory mapped locations within 

45 the controller; comparing the digital values with limit values, generating flag values based on the limit values, and 
storing the flag values in predefined memory mapped locations within the controller; generating control signals to 
control operation of the laser transmitter in accordance with one or more values stored in the predefined memory 
mapped locations within the controller; analog to digital conversion circuitry for receiving a plurality of analog signals 
from the laser transmitter and photodiode receiver, converting the received analog signals into digital values, and 

50 storing the digital values in predefined memory mapped locations within the controller 

[0033] Advantageously, the method of controlling an optoelectronic transceiver having a laser transmitter and a pho- 
todiode receiver further includes generating and storing in a register a time value corresponding to cumulative operation 
time of the transceiver, wherein the register in which the time value is accessed by the reading step as a memory 
mapped within the controller 

55 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0034] Additional objects and features ofthe invention will be more readily apparent from the following detailed de- 
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scription and appended claims when taken in conjunction with the drawings, in which: 
Fig. 1 is a block diagrann of a prior art optoelectronic transceiver. 

Fig. 2 is a block diagrann of an optoelectronic transceiver in accordance with the present invention. 
5 Fig. 3 is a block diagram of modules within the controller of the optoelectronic transceiver of Fig. 2. 



DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 



[0035] A transceiver 1 00 based on the present invention is shown in Figs. 2 and 3. The transceiver 100 contains a 
10 Receiver Optical Subassembly (ROSA) 1 02 and Transmitter Optical Subassembly (TOSA) 1 03 along with associated 
post-amplifier 104 and laser driver 105 integrated circuits that communicate the high speed electrical signals to the 
outside world. In this case, however, all other control and setup functions are implemented with a third single-chip 
integrated circuit 110 called the controller IC. 

[0036] The controller 101 1 0 handles all low speed communications with the end user. These include the standardized 
15 pin functions such as Loss of Signal (LOS) 111, Transmitter Fault Indication (TX FAULT) 14, and the Transmitter Disable 
Input (TXDIS) 13. The controller IC 110 has a two wire serial interface 121, also called the memory interface, for 
accessing memory mapped locations in the controller. Memory Map Tables 1,2,3 and 4, below, are an exemplary 
memory map for one embodiment of a transceiver controller, as implemented in one embodiment of the present in- 
vention. It is noted that Memory Map Tables 1,2,3 and 4, in addition to showing a memory map of values and control 
20 features described in this document, also show a number of parameters and control mechanisms that are outside the 
scope of this document and thus are not part of the present invention. 

[0037] The interface 121 is coupled to host device interface input/output lines, typically clock (SCL) and data (SDA) 
lines, 1 5 and 1 6. In the preferred embodiment, the serial interface 121 operates in accordance with the two wire serial 
interface standard that is also used in the GBIC and SFP standards, however other serial interfaces could equally well 

25 be used in alternate embodiments. The two wire serial interface 1 21 is used for all setup and querying of the controller 
IC 110, and enables access to the optoelectronic transceiver's control circuitry as a memory mapped device. That is, 
tables and parameters are set up by writing values to predefined memory locations of one or more nonvolatile memory 
devices 120, 122, 128 (e.g., EEPROM devices) in the controller, whereas diagnostic and other output and status values 
are output by reading predetermined memory locations of the same nonvolatile memory devices 120, 121 , 122. This 

30 technique is consistent with currently defined serial ID functionality of many transceivers where a two wire serial inter- 
face is used to read out identification and capability data stored in EEPROM. 

[0038] It is noted here that some of the memory locations in the memory devices 120, 122, 128 are dual ported, or 
even triple ported in some instances. That is, while these memory mapped locations can be read and in some cases 
written via the serial interface 121 , they are also directly accessed by other circuitry in the controller 110. For instance, 

35 certain "margining" values stored in memory 120 are read and used directly by logic 134 to adjust (i.e., scale upwards 
or downwards) drive level signals being sent to the D/A output devices 123. Similarly, there are flags stored memory 
128 that are (A) written by logic circuit 131 , and (B) read directly by logic circuit 133. An example of a memory mapped 
location not in memory devices but that is effectively dual ported is the output or result register of clock 132. In this 
case the accumulated time value in the register is readable via the serial interface 1 21 , but is written by circuitry in the 

40 clock circuit 132. 

[0039] In addition to the result register of the clock 132, other memory mapped locations in the controller may be 
implemented as registers at the input or output of respective sub-circuits of the controller. For instance, the margining 
values used to control the operation of logic 134 may be stored in registers in or near logic 134 instead of being stored 
within memory device 128. In another example, measurement values generated by the ADC 127 may be stored in 
45 registers. The memory interface 121 is configured to enable the memory interface to access each of these registers 
whenever the memory interface receives a command to access the data stored at the corresponding predefined mem- 
ory mapped location. In such embodiments, "locations within the memory" include memory mapped registers through- 
out the controller. 

[0040] In an alternate embodiment, the time value in the result register of the clock 132, or a value corresponding 
50 to that time value, is periodically stored in a memory location with the memory 128 (e.g., this may be done once per 
minute, or one per hour of device operation). In this alternate embodiment, the time value read by the host device via 
interface 121 is the last time value stored into the memory 128, as opposed to the current time value in the result 
register of the clock 1 32. 

[0041] As shown in Figs. 2 and 3, the controller IC 110 has connections to the laser driver 105 and receiver compo- 
55 nents. These connections serve multiple functions. The controller IC has a multiplicity of D/A converters 123. In the 
prefered embodiment the D/A converters are implemented as current sources, but in other embodiments the D/A 

converters may be implemented using voltage sources, and in yet other embodiments the D/A converters may be 
implemented using digital potentiometers. In the preferred embodiment, the output signals of the D/A converters are 
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used to control key parameters of the laser driver circuit 105. In one ennbodiment, outputs of the D/A converters 123 
are use to directly control the laser bias current as well as control of the level AC nnodulation to the laser (constant bias 
operation). In another ennbodiment, the outputs of the D/A converters 123 of the controller 110 control the level of 
average output power of the laser driver 105 in addition to the AC modulation level (constant power operation). 

5 [0042] In a preferred embodiment, thecontroller 110 includes mechanisms to compensate fortemperature dependent 
characteristics of the laser. This is implemented in the controller 1 1 0 through the use of temperature lookup tables 1 22 
that are used to assign values to the control outputs as a function of the temperature measured by a temperature 
sensor 125 within the controller IC 110. In alternate embodiments, the controller 110 may use D/A converters with 
voltage source outputs or may even replace one or more of the D/A converters 123 with digital potentiometers to control 

10 the characteristics of the laser driver 1 05. It should also be noted that while Fig. 2 refers to a system where the laser 
driver 105 is specifically designed to accept inputs from the controller 110, it is possible to use the controller IC 110 
with many other laser driver ICs to control their output characteristics. 

[0043] In addition to temperature dependent analog output controls, the controller IC may be equipped with a mul- 
tiplicity of temperature independent (one memory set value) analog outputs. These temperature independent outputs 

15 serve numerous functions, but one particularly interesting application is as a fine adjustment to other settings of the 
laser driver 1 05 or postamp 1 04 in order to compensate for process induced variations in the characteristics of those 
devices. One example of this might be the output swing of the receiver postamp 104. Normally such a parameter would 
be fixed at design time to a desired value through the use of a set resistor, It often turns out, however, that normal 
process variations associated with the fabrication of the postamp integrated circuit 104 induce undesirable variations 

20 in the resulting output swing with a fixed set resistor. Using the present invention, an analog output of the controller IC 
1 1 0, produced by an additional D/A converter 1 23, is used to adjust or compensate the output swing setting at manu- 
facturing setup time on a part-by-part basis. 

[0044] In addition to the connection from the controller to the laser driver 1 05, Fig. 2 shows a number of connections 
from the laser driver 1 05 to the controller IC 1 1 0, as well as similar connections from the ROSA 1 06 and Postamp 1 04 

25 to the controller IC 11 0. These are analog monitoring connections that the controller IC 1 1 0 uses to provide diagnostic 
feedback to the host device via memory mapped locations in the controller IC. The controller IC 110 in the preferred 
embodiment has a multiplicity of analog inputs. The analog input signals indicate operating conditions of the transceiver 
and/or receiver circuitry. These analog signals are scanned by a multiplexer 124 and converted using an analog to 
digital converter (ADC) 127. The ADC 127 has 12 bit resolution in the preferred embodiment, although ADC's with 

30 other resolution levels may be used in other embodiments. The converted values are stored in predefined memory 
locations, for instance in the diagnostic value and flag storage device 128 shown in Fig. 3, and are accessible to the 
host device via memory reads. These values are calibrated to standard units (such as millivolts or microwatts) as part 
of a factory calibration procedure. 

[0045] The digitized quantities stored in memory mapped locations within the controller IC include, but are not limited 

35 to, the laser bias current, transmitted laser power, and received power (as measured by the photodiode detector in the 
ROSA 102). In the memory map tables (e.g., Table 1), the measured laser bias current is denoted as parameter Bj^, 
the measured transmitted laser power is denoted as Pjn, and the measured received power is denoted as Rj^. The 
memory map tables indicate the memory locations where, in an exemplary implementation, these measured values 
are stored, and also show where the corresponding limit values, flag values, and configuration values (e.g., for indicating 

40 the polarity of the flags) are stored. 

[0046] As shown in Fig. 3, the controller 110 includes a voltage supply sensor 126. An analog voltage level signal 
generated by this sensor is converted to a digital voltage level signal by the ADC 127, and the digital voltage level 
signal is stored in memory 128. In a preferred embodiment, the A/D input mux 124 and ADC 127 are controlled by a 
clock signal so as to automatically, periodically convert the monitored signals into digital signals, and to store those 

45 digital values in memory 128. 

[0047] Furthermore, as the digital values are generated, the value comparison logic 1 31 of the controller compares 
these values to predefined limit values. The limit values are preferably stored in memory 128 at the factory, but the 
host device may overwrite the originally programmed limit values with new limit values. Each monitored signal is au- 
tomatically compared with both a lower limit and upper limit value, resulting in the generation of two limit flag values 

50 that are then stored in the diagnostic value and flag storage device 1 28. For any monitored signals where there is no 
meaningful upper or lower limit, the corresponding limit value can be set to a value that will never cause the corre- 
sponding flag to be set. 

[0048] The limit flags are also sometimes call alarm and warning flags. The host device (or end user) can monitor 
these flags to determine whether conditions exist that are likely to have caused a transceiver link to fail (alarm flags) 
55 or whether conditions exist which predict that a failure is likely to occur soon. Examples of such conditions might be a 
laser bias current which has fallen to zero, which is indicative of an immediate failure of the transmitter output, or a 

laser bias current in a constant power mode which exceeds its nominal value by more than 50%, which is an indication 
of a laser end-of-life condition. Thus, the automatically generated limit flags are useful because they provide a simple 
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pass-fail decision on the transceiver functionality based on internally stored limit values. 

[0049] In a preferred embodinnent, fault control and logic circuit 133 logically OR's the alarm and warning flags, along 
with the internal LOS (loss of signal) input and Fault Input signals, to produce a binary Transceiver fault (TxFault) signal 
that is coupled to the host interface, and thus made available to the host device. The host device can be programmed 
to monitorthe TxFault signal, and to respond to an assertion of the TxFault signal by automatically reading all the alarm 
and warning flags in the transceiver, as well as the corresponding monitored signals, so as to determine the cause of 
the alarm or warning. 

[0050] The fault control and logic circuit 133 furthermore conveys a loss of signal (LOS) signal received from the 
receiver circuit (ROSA, Fig. 2) to the host interface. 

[0051] Another function of the fault control and logic circuit 133 is to disable the operation of the transmitter (TOSA, 
Fig. 2) when needed to ensure eye safety. There is a standards defined interaction between the state of the laser driver 
and the Tx Disable output, which is implemented by the fault control and logic circuit 133. When the logic circuit 133 
detects a problem that might result in an eye safety hazard, the laser driver is disabled by activating the Tx Disable 
signal of the controller, The host device can reset this condition by sending a command signal on the TxDisableCmd 
line of the host interface, 

[0052] Yet another function of the fault control and logic circuit 1 33 is to determine the polarity of its input and output 
signals in accordance with a set of configuration flags stored in memory 128. For instance, the Loss of Signal (LOS) 
output of circuit 1 33 may be either a logic low or logic high signal, as determined by a corresponding configuration flag 
stored in memory 128. 

[0053] Other configuration flags (see Table 4) stored in memory 128 are used to determine the polarity of each of 
the warning and alarm flags. Yet other configuration values stored in memory 128 are used to determine the scaling 
applied by the ADC 127 when converting each of the monitored analog signals into digital values. 

[0054] In an alternate embodiment, another input to the controller 102, atthe host interface, is a rate selection signal. 
In Fig. 3 the rate selection signal is input to logic 133. This host generated signal would typically be a digital signal that 
specifies the expected data rate of data to be received by the receiver (ROSA 102). For instance, the rate selection 
signal might have two values, representing high and low data rates (e.g., 2.5 Gb/s and 1.25 Gb/s). The controller 
responds to the rate selection signal by generating control signals to set the analog receiver circuitry to a bandwidth 
corresponding to the value specified by the rate selection signal. 

[0055] While the combination of all of the above functions is desired in the preferred embodiment of this transceiver 
controller, it should be obvious to one skilled in the art that a device which only implements a subset of these functions 
would also be of great use. Similarly, the present invention is also applicable to transmitters and receivers, and thus 
is not solely applicable to transceivers. Finally, it should be pointed out that the controller of the present invention is 
suitable for application of multichannel optical links. 



TABLE 1 



MEMORY MAP FOR TRANSCEIVER CONTROLLER 


Memory Location (Array 
0) 


Name of 
Location 


Function 


OOh - 5Fh 


IEEE Data 


This memory block is used to store required GBIG data 


60h 


Temperature MSB 


This byte contains the MSB of the 15-bit 2's complement 
temperature output from the temperature sensor. 


61h 


Temperature LSB 


This byte contains the LSB of the 15-bit 2's complement 
temperature output from the temperature sensor. (LSB is Ob). 


62h - 63h 


Vcc Value 


These bytes contain the MSB (62h) and the LSB (63h) of the 
measured V^c (15-bit number, with a Ob LSbit) 


64h - 65h 


Bjn Value 


These bytes contain the MSB (64h) and the LSB (65h) of the 
measured B■^^ (laser bias current) (15-bit number, with a Ob 
LSbit) 


66h - 67h 


Pin Value 


These bytes contain the MSB (66h) and the LSB (67h) of the 
measured Pj^, (transmitted laser power) (15-bit number, with a 
Ob LSbit) 


68h - 69h 


Rjn Value 


These bytes contain the MSB (68h) and the LSB (69h) of the 
measured Rj^ (received power) (15-bit number, with a Ob LSbit) 
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TABLE 1 (continued) 





MEMORY MAP FOR TRANSCEIVER CONTROLLER 


5 


Memory Location (Array 
0) 


Name of 
Location 


Function 






6Ah - 


6Dh 


Reserved 


Reserved 




6Eh 


lO States 


This byte shows the logical value of the I/O pins 


10 


6Fh 


A/D Updated 


Allows the user to verify if an update fronn the A/D has occurred 
to the 5 values: tennperature, V^c, Bj^, Pj^ and Rj^. The user 
writes the byte to OOh. Once a conversion is complete for a give 
value, its bit will change to '1 '. 


15 




70h - 


73h 


Alarm Flags 


These bits reflect the state of the alarms as a conversion 
updates. High alarm bits are '1' if converted value is greater than 
corresponding high limit. Low alarm bits are '1' if converted 
vnlijp 1^ Ip^q thnn rnrrp^nonrJinn Inw limit Othprwi^p hit^ nrp 
Ob. 


20 




74h - 


77h 


Warning Flags 


These bits reflect the state of the warnings as a conversion 
updates. High warning bits are '1 ' if converted value is greater 
than corresponding high limit, Low warning bits are '1' if 
converted value is less than corresponding low limit. Otherwise, 
bits are Ob. 


25 




78h - 


7Ah 


Reserved 


Reserved 





7Bh - 7Eh 


Password Entry Bytes 


The four bytes are used for password entry. The 


30 




PWE Byte 3 (7Bh) 


entered password will detemriine the user's 




MSByte 


read/write privileges. 






PWE Byte 2 (7Ch) 








PWE Byte 1 (7Dh) 








PWE Byte 0 (7Eh) 




35 




LSByte 






7Fh 


Array Select 


Writing to this byte detemnines which of the 








upper pages of memory is selected for reading 








and writing. 


40 






Oxh (Array x Selected) 






Where x= 1, 2, 3, 4 or 5 




80h-FFh 




Reserved / not currently implemented 



50 



■Memory Location (Array 1) 


Name of Location 


Function of Location 


80h - FFh 




Data EEPROM 




Memory Location (Array 2) 


Name of Location 


Function of Location 


80h - FFh 




Data EEPROM 



Memory Location (Array 
3) 


Name of Location 


Function of Location 


80h-81h 


Temperature High 


The value written to this location serves as the 
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(continued) 



Memory Location (Array 
3) 


Name of Location 


Function of Location 


88h - 89h 
90h-91h 
98h - 99h 
AOh - A1 h 


Alarm 

V^c High Alarm 
Bjn High Alarm 
Pjn High Alarm 
Rjn High Alarm 


high alarm limit. Data format is the same as the 
corresponding value (temperature, V^c, Bj^, Pjn, 

Rin)- 


82h - 83h 
8Ah - 8Bh 
92h - 93h 
9Ah - 9Bh 
A2h - A3h 


Temperature Low 
Alarm 

Low Alarm 
Bjn Low Alarm 
Pjn Low Alarm 
Rjn Low Alarm 


The value written to this location serves as the 
low alarm limit. Data format is the same as the 
corresponding value (temperature, V^c, Bjp, Pjn, 


84h - 85h 
8Ch - 8Dh 
94h - 95h 
9Ch - 9Dh 
A4h - A5h 


Temp High Warning 

High Warning 
Bin High Warning 
Pjn High Warning 
Rjn High Warning 


The value written to this location serves as the 
high warning limit. Data format is the same as 
the corresponding value (temperature, M^, Bjn, 

Pin. RJ- 


86h - 87h 
8Eh - 8Fh 
96h - 97h 
9Eh -9Fh 
A6h - A7h 


Temperature Low 
Warning 

Low Warning 
Bjn Low Warning 
Pjn Low Warning 
Rjn Low Warning 


The value written to this location serves as the 
low warning limit. Data format is the same as 
the corresponding value (temperature, Vpc, Bjn, 

Pirr Rjn)- 


A8h - AFh, 
C5h 

BOh - B7h, 

C6h 

B8h - BFh, 
C7h 


□out control 0-8 
Fout control 0-8 
Lout control 0-8 


Individual bit locations are defined in Table 4. 


COh 


Reserved 


Reserved 


C1h 


Prescale 


Selects MCLK divisor for X-delay CLKS. 


C2h 
C3h 
C4h 


D^^jt Delay 
Fout Delay 
Lout Delay 


Selects number of prescale clocks 


C8h - C9h 
CAh - CBh 
CCh - CDh 
CEh - CFh 


- A/D Scale 
Bin - A/D Scale 
Pjn - A/D Scale 
Rjn - A/D Scale 


16 bits of gain adjustment for corresponding A/D 
conversion values. 


DOh 


Chip Address 


Selects chip address when external pin ASEL is 
low. 


D1h 


Margin #2 


Finisar Selective Percentage (FSP) for D/A #2 


D2h 


Margin #1 


Finisar Selective Percentage (FSP) for D/A #1 


D3h - D6h 


PW1 Byte 3 (D3h) 
MSB 

PW1 Byte 2 (D4h) 
PW1 Byte 1 (D5h) 


The four bytes are used for password 1 entry. 
The entered password will determine the Finisar 
customer's read/write privileges. 
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(continued) 



Memory Location (Array 
3) 


Name of Location 


Function of Location 




PW1 Byte 0 (D6h) 
LSB 




D7h 


D/A Control 


This byte deternnines if the D/A outputs source 
or sink current, and it allows for the outputs to 
be scaled. 


D8h - DFh 


Bjn Fast Trip 


These bytes define the fast trip comparison over 
tennperature. 


EOh - E3h 


Pjn Fast Trip 


These bytes define the fast trip comparison over 
temDeratu re 


E4h - E7h 


R- Fast Trio 

1 lip 1 CiO L 1 1 Ik/ 


Thpcp hvfp<5 define the fast trio conriDarison over 

1 IIV^O^ L^yL^O UWIIII^ LI IdwL LI Ik/ WWl 1 Ik/Cll lOV/l 1 V^V^I 

temperature. 


E8h 


Conflauration Override Bvte 


Location of the bits is defined in Table 4 

^WvuLIVl 1 wl LI Iw 1 LO lO Uvl II IWu III 1 C4kyiw 


E9h 


Reserved 


Reserved 


EAh - EBh 


Internal State Bytes 


Location of the bits is defined in Table 4 


ECh 


I/O States 1 


Location of the bits is defined in Table 4 


EDh - EEh 


D/A Out 


Magnitude of the temperature compensated D/A 

outputs 


EFh 


Temperature Index 


Address pointer to the look-up Arrays 


FOh - FFh 


Reserved 


Reserved 



30 



iVIemory Location (Array 4) 


Name of Location 


Function of Location 


OOh - FFh 




D/A Current vs. Temp #1 

(User-Defnied Look-up Array #1). 



Memory Location (Array 5) 


Name of Location 


Function of Location 


OOh - FFh 




D/A Current vs. Temp #2 

(User-Defined Look-up Array #2) 



TABLE 2 - 



DETAIL MEIVIORY DESCRIPTIONS - A/D VALUES AND STATUS BITS 


Byte 


Bit 


Name 


Description 


Converted analog values. Calibrated 16 bit data. 


96 (60h) 


All 


Temperature IVISB 


Signed 2's complement integer temperature (-40 to +125C) Based on 
internal temperature measurement 


97 


All 


Temperature LSB 


Fractional part of temperature (count/256) 


98 


All 


Vcc MSB 


Internally measured supply voltage in transceiver. Actual voltage is full 
16 bit value* 100 uVolt. 


99 


All 


Vcc LSB 


(Yields range of 0 - 6.55V) 


100 


All 


TX Bias MSB 


Measured TX Bias Current in mA Bias current is full 1 6 bit value *(1 /256) 
mA. 
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TABLE 2 - (continued) 





DETAIL MEMORY DESCRIPTIONS - A/D VALUES AND STATUS BITS 




Byte 


Bit 


Name 


Description 


5 


Converted analog values. Calibrated 16 bit data. 




101 


All 


TX Bias LSB 


(Full range of 0 - 256 mA possible with 4 uA resolution) 


10 


102 


All 


TX Power MSB 


Measured TX output power in nnW. Output is full 1 6 bit value *(1/2048) 
mW. 


103 


All 


TX Power LSB 


Full range of 0 - 32 nnW possible with 0.5 resolution, or -33 to +15 


15 


104 


All 


RX Power MSB 


Measured RX input power in mW RX power is full 16 bit value *(1/1 6384) 
mW. 


105 


All 


RX Power LSB 


(Full range of 0 - 4 nnW possible with 0.06 jo^W resolution, or -42 to +6 
dBm) 




106 


All 


Reserved MSB 


Reserved for l^t future definition of digitized analog input 


20 


107 


All 


Reserved LSB 


Reserved for 1^* future definition of digitized analog input 




108 


All 


Reserved MSB 


Reserved for 2^^ future definition of digitized analog input 




109 


All 


Reserved LSB 


Reserved for 2"^^ future definition of digitized analog input 




General Status Bits 


25 


110 


7 


TX Disable 


Digital state of the TX Disable Input Pin 




110 


6 


Reserved 






110 


5 


Reserved 




30 


110 


4 


Rate Select 


Digital state of the SFP Rate Select Input Pin 




110 


3 


Reserved 






110 


2 


TX Fault 


Digital state of the TX Fault Output Pin 




110 


1 


LOS 


Digital state of the LOS Output Pin 


35 


110 


0 


Power-On-Logic 


Indicates transceiver has achieved power up and data valid 




111 


7 


Temp A/D Valid 


Indicates AID value in Bytes 96/97 is valid 




111 


6 


Vcc A/D Valid 


Indicates A/D value in Bytes 98/99 is valid 


40 


111 


5 


TX Bias A/D Valid 


Indicates A/D value in Bytes 100/101 is valid 




111 


4 


TX Power A/D Valid 


Indicates AID value in Bytes 102/103 is valid 




111 


3 


RX Power A/D Valid 


Indicates A/D value in Bytes 104/105 is valid 


45 


111 


2 


Reserved 


Indicates AID value in Bytes 106/107 is valid 


111 


1 


Reserved 


Indicates AID value in Bytes 108/109 is valid 




111 


0 


Reserved 


Reserved 



TABLE 3 - 



DETAIL MEMORY DESCRIPTIONS - ALARM AND WARNING FLAG BITS 


Byte 


Bit 


Name 


Description 


Alarm and Warning Flag Bits 


112 


7 


Temp High Alarm 


Set when internal temperature exceeds high alann level. 


112 


6 


Temp Low Alarm 


Set when internal temperature is below low alarm level. 



EP 1 471 671 A2 

TABLE 3 - (continued) 





DETAIL MEMORY DESCRIPTIONS - ALARM AND WARNING FLAG BITS 




Byte 


Bit 


Name 


Description 


5 


Alarm and Warning Flag Bits 




112 


5 


Vcc High Alann 


Set when internal supply voltage exceeds high alarm level. 




112 


4 


Low Alamn 


Set when internal supply voltage is below low alann level. 


10 


112 


3 


TX Bias High Alarm 


Set when TX Bias current exceeds high alarm level. 




112 


2 


TX Bias Low Alarm 


Set when TX Bias current is below low alarm level. 




112 


1 


TX Power High Alarm 


Set when TX output power exceeds high alarm level. 




112 


0 


TX Power Low Alarm 


Set when TX output power is below low alarm level. 


113 


7 


RX Power High Alarm 


Set when Received Power exceeds high alarm level. 




113 


6 


RX Power Low Alarm 


Set when Received Power is below low alarm level. 




113 


5-0 


Reserved Alarm 




20 


114 


All 


Reserved 






115 


All 


Reserved 






116 


7 


Temp High Warning 


Set when internal temperature exceeds high warning level. 


25 


116 


6 


Temp Low Warning 


Set when internal temperature is below low warning level. 


116 


5 


V^c High Warning 


Set when internal supply voltage exceeds high warning level. 




116 


4 


V^c Low Warning 


Set when internal supply voltage is below low warning level. 




116 


3 


TX Bias High Warning 


Set when TX Bias current exceeds high warning level. 


30 


116 


2 


TX Bias Low Warning 


Set when TX Bias current is below low warning level. 




116 


1 


TX Power High Warning 


Set when TX output power exceeds high warning level. 




116 


0 


TX Power Low Warning 


Set when TX output power is below low warning level. 


35 


117 


7 


RX Power High Warning 


Set when Received Power exceeds high warning level. 


117 


6 


RX Power Low Warning 


Set when Received Power is below low warning level. 




117 


5 


Reserved Warning 






117 


4 


Reserved Warning 




40 


117 


3 


Reserved Warning 






117 


2 


Reserved Warning 






117 


1 


Reserved Warning 




45 


117 


0 


Reserved Warning 




118 


All 


Reserved 






119 


All 


Reserved 





50 
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10 



15 



20 



25 



30 



LU 
_l 
CD 



35 



40 



45 



50 



55 



DO 



DC 



X 



X 



DQ 



DQ 



CD 



DQ 



DQ 



DQ 



DQ 



DQ 



DQ 
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Claims 

1 . Circuitry for monitoring an optoelectronic device, comprising: 

memory, including one or more memory arrays for storing information related to the optoelectronic device; 
analog to digital conversion circuitry configured to receive a plurality of analog signals from tine optoelectronic 
device, the analog signals corresponding to operating conditions of the optoelectronic device, convert the 
received analog signals into digital values, and store the digital values in predefined locations within the mem- 
ory; 

comparison logic configured to compare the digital values with limit values to generate flag values, wherein 
the flag values are stored in predefined flag storage locations within the memory during operation of the op- 
toelectronic device; and 

an interface configured to enable a host to read from host-specified locations within the memory, including the 
predefined flag storage locations, in accordance with commands received from the host, 

2. The circuitry of claim 1 , wherein the analog to digital conversion circuitry Is configured to convert a power level 
signal into a digital power level value and to store the digital power level value in a predefined power level location 
within the memory. 

3. The circuitry of claim 1 , wherein the comparison logic includes logic for comparing the digital power level value 
with a power limit value, generating a power flag value based on the comparison of the digital power signal with 
the power limit value, and storing the power flag value in a predefined power flag location within the memory. 

4. The circuitry of claim 1 , wherein the analog to digital conversion circuitry is configured to convert a temperature 
signal into a digital temperature value and to storethe digital temperature value in a predefined temperature location 
within the memory. 

5. The circuitry of claim 4, wherein the comparison logic includes logic for comparing the digital temperature value 
with a temperature limit value, generating a temperature flag value based on the comparison of the digital tem- 
perature signal with the temperature limit value, andstoring the temperature flag value In a predefined temperature 
flag location within the memory. 

6. The circuitry of claim 1 , wherein the plurality of analog signals includes two analog signals selected from the set 
consisting of laser bias current, laser output power, and received power. 

7. The circuitry of claim 1 , wherein the analog to digital conversion circuitry is configured to receive a voltage signal 
from a source external to the monitoring circuitry, convert the voltage signal into a digital voltage value and store 
the digital voltage value in a respective predefined location within the memory. 

8. A method of monitoring an optoelectronic device, comprising: 

receiving a plurality of analog signals from the optoelectronic device, the analog signals corresponding to 
operating conditions of the optoelectronic device, converting the received analog signals into digital values, 
and storing the digital values in predefined locations within a memory; 

comparing the digital values with limit values to generate flag values, and storing the flag values in predefined 
flag locations within the memory; and 

in accordance with instructions received from a host device, enabling the host device to read from host-spec- 
ified locations within the memory, including the predefined flag locations. 

9. The method of claim 8, further including: 

generating a power level signal corresponding to a power supply voltage level of the optoelectronic device, 
converting the power level signal into a digital power level value and storing the digital power level value in a 
predefined power level location within the memory. 

10. The method of claim 9, further including: 

comparing the digital power level value with a power level limit value, generating a power level flag value 
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based on the comparison of the digital power level signal with the power level limit value, and storing the power 
level flag value in a predefined power level flag location within the memory. 

1. The method of claim 8, further including 

generating a temperature signal corresponding to a temperature of the optoelectronic device, converting the 
temperature signal into a digital temperature value and stohng the digital temperature value in a predefined tem- 
perature location within the memory. 

2. The method of claim 11 , wherein 

comparing the digital temperature value with a temperature limit value, generating a temperature flag value 
based on the comparison of the digital temperature signal with the temperature limit value, and storing the tem- 
perature flag value in a predefined temperature flag location within the memory. 

3. The method of claim 8, wherein the plurality of analog signals includes two analog signals selected from the set 
consisting of laser bias current, laser output power, and received power. 

4. The method of claim 8, including receiving a voltage signal from a source external to the optoelectronic device, 
converting the voltage signal into a digital voltage value and storing the digital voltage value in a respective pre- 
defined location within the memory. 
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